package com.accelstack.cmp.repository;

import com.accelstack.cmp.entity.GpuModel;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.data.jpa.repository.Query;
import org.springframework.stereotype.Repository;

import java.util.List;

/**
 * GPU型号Repository
 */
@Repository
public interface GpuModelRepository extends JpaRepository<GpuModel, Long> {
    
    /**
     * 根据厂商查询GPU型号
     */
    List<GpuModel> findByVendor(String vendor);
    
    /**
     * 根据显存大小查询GPU型号
     */
    List<GpuModel> findByVramGb(Integer vramGb);
    
    /**
     * 根据显存范围查询GPU型号
     */
    List<GpuModel> findByVramGbBetween(Integer minVram, Integer maxVram);
    
    /**
     * 根据名称模糊搜索GPU型号
     */
    List<GpuModel> findByNameContainingIgnoreCase(String keyword);
    
    /**
     * 查询所有不重复的厂商列表
     */
    @Query("SELECT DISTINCT g.vendor FROM GpuModel g WHERE g.vendor IS NOT NULL ORDER BY g.vendor")
    List<String> findAllDistinctVendors();
}

